package com.example.smartpark.model;

import com.baomidou.mybatisplus.annotation.*;
import lombok.Data;

import java.io.Serializable;
import java.math.BigDecimal;
import java.util.Date;

/**
 * 预约记录实体类
 * 对应数据库中的reservation表
 */
@Data
@TableName("reservation")
public class Reservation implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * 主键ID，自增
     */
    @TableId(value = "id", type = IdType.AUTO)
    private Long id;

    /**
     * 用户ID，关联用户表
     */
    private Integer userId;

    /**
     * 车辆ID，关联车辆表
     */
    private Integer vehicleId;

    /**
     * 车位ID，关联车位表
     */
    private Integer parkingSpaceId;

    /**
     * 预约开始时间
     */
    private Date startTime;

    /**
     * 预约结束时间
     */
    private Date endTime;

    /**
     * 状态（0-待审核，1-已确认，2-已使用，3-已取消，4-已拒绝）
     */
    private Integer status;

    /**
     * 预约费用
     */
    private BigDecimal fee;

    /**
     * 是否已支付（0-未支付，1-已支付）
     */
    private Integer isPaid;

    /**
     * 支付ID，关联支付记录表
     */
    private Integer paymentId;

    /**
     * 备注信息
     */
    private String remark;

    /**
     * 创建时间
     */
    @TableField(fill = FieldFill.INSERT)
    private Date createdAt;

    /**
     * 更新时间
     */
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private Date updatedAt;

    /**
     * 是否逻辑删除（0-未删除，1-已删除）
     */
    @TableLogic
    private Integer deleted;
} 